草庐IT

node.js - meteor 用于非常快的数据

全部标签

ruby-on-rails - 将没有默认值的 NOT NULL 字段添加到填充的数据库中

我有一个表,我们称它为MyTable。它是Postgresql数据库的一部分。MyTable中有很多条目,比方说超过一百万。我想向该表中添加一个字段,我们将其命名为MyNewField。它由ActiveRecord迁移添加。此字段没有默认值且不可为空。结果,在它的迁移类中将是这样的:classAddMyFieldToMyTable但是,它会触发一个错误(PG::NotNullViolation),因为该表已经包含行,所有这些行的MyField都设置为NULL。我想做的是:添加没有默认值且可空设置为false的行(不触发PG::NotNullViolation)。然后,将另一个表中的值插

ruby -/lib 中的 <appname>.rb 文件在 Ruby 项目中通常用于什么?

引用这个问题:Idealrubyprojectstructure我注意到appname.rb在lib中,并且是顶级。我在Github上阅读了一些Rake源代码,我注意到他们的项目结构几乎相同。他们在/lib中有一个顶级“rake.rb”文件,但我不确定它的用途。在ThePickaxe(ProgrammingRuby1.9)中,他们展示了一个构建小型项目的示例,其目录结构与上面几乎相同,但没有提及/lib中顶级.rb的用法。所以,我的问题是:这个东西在Ruby项目中通常用于什么?抱歉,如果这是一个愚蠢的问题,我敢肯定,但我对Ruby还比较陌生。我现在不太了解Ruby-foo。;)谢谢。

ruby-on-rails - 适用于 Windows 上 Rails3 的工作 IDE

我很难在Windows中为Rails3配置NetBeans。我遇到了很多问题,很多人甚至在这里报告过。所以我的问题是:以下哪些IDE最适合WindowsBox中的Rails3:ruby矿科莫多集成开发环境RadRails看,我不想开始讨论(有点xvsy)。我只是想从已经在使用Windows使用Rails3进行开发的人们那里了解从长远来看什么是更好的选择。谢谢!编辑NetBeans问题Issue1Issue2注意:我现在正在使用RubyMine,没有遇到任何问题 最佳答案 我正在使用RubyMine.您可以免费试用30天。在使用Rub

ruby-on-rails - 如何在 ruby​​onrails 上将数据从模型导出到 excel 文件

我正在尝试将数据从我的模型导出到Excel电子表格。我见过3种方式使用我不明白如何使用的电子表格gem,我看到的示例是写入本地文件,但我正在寻找每次用户点击链接时都会生成一个文件。创建一个名为export的方法,并在那里运行查询,然后在我看来创建一个export.xls文件,然后该文件创建我想将表格导出到excel文件,但是这种做法不允许我创建多张纸。学习了本教程,http://oldwiki.rubyonrails.org/rails/pages/HowToExportToExcel,但是这里没有显示如何将链接放在View中,在我看来我在路由中遗漏了一些东西,我可以提供github以

ruby-on-rails - 当多个应用程序在 Ruby 中共享同一个数据库时如何管理迁移?

我有一个Rails应用程序和一个Sinatra应用程序,共享同一个数据库。Sinatra应用程序使用ActiveRecord。我能否从每个应用程序中运行迁移,就好像它们在同一个应用程序中一样?这会导致任何问题吗?Rails应用程序中的schema.rb文件通过以下方式跟踪当前迁移ActiveRecord::Schema.define(:version=>20121108154656)do但是,Sinatra应用如何知道数据库的当前版本?Rails3.2.2,Ruby1.9.3。 最佳答案 schema_migrations表中的版本

ruby - 用于删除下一个/尾随字符的转义序列?

除了使用\x08删除前导字符外,是否可以同时删除尾随字符?是否有一个转义序列将删除下一个字符而不是前一个字符?我看到delete显然映射到ASCII127,即Hex7F,但以下代码:puts"a\x08b\x7fcd"产生b⌂cd我预计\x7f会删除它后面的'c'字符,但它没有。 最佳答案 您实际上并没有使用\x08删除任何内容,您只是用“b”覆盖了“a”。想象一下您使用电传纸质终端的过去。您实际上会在纸上看到的是打印的“a”,电传打字机会备份一个空格,然后在其上打印“b”。所有非打印的ascii码都是为了控制电传纸终端的移动而发明

ruby-on-rails - 基于数据库模型的动态 Rails 路由

所以我正在构建一个需要基于两种不同类型的路由的Rails站点我有一个语言模型和一个类别模型所以我需要能够转到语言路径/ruby以查看顶级ruby​​资源,还可以转到/books以查看所有语言的顶级书籍我试过这样的路线get'/:language',to:"top_voted#language"get'/:category',to:"top_voted#category"问题是逻辑无法弄清楚两者之间的区别,导致后端发生一些冲突这个我也试过Language.all.eachdo|language|get"#{language.name}",to:"top_voted#language",:

ruby - ruby 中的过程和数据抽象

我是Ruby新手。我正在学习ruby​​中的抽象原则。据我了解,过程抽象是对用户隐藏实现细节,或者只是专注于要点而忽略细节。我关心的是如何实现它1)是不是一个简单的函数调用就这样#functiontosortarray#@paramsarray[Array]tobesortdefmy_sort(array)returnarrayifarray.sizearray[i+1]array[i],array[i+1]=array[i+1],array[i]swapped=trueendendendarrayend然后这样调用sorted_array=my_sort([12,34,123,43,

ruby-on-rails - Ruby 类评估,validates_inclusion_of 与动态数据

如果我有如下的ActiveRecord模型classFooself.allowed_typesdefself.allowed_types#somecodethatreturnsanenumerableendend这不起作用,因为在评估验证时尚未定义allowed_types方法。我能想到的所有修复基本上都是围绕将方法定义移到验证之上,以便在需要时可用。我明白这可能更像是一个编码风格问题(我希望我的所有验证都在模型顶部,方法在底部)但我觉得应该有某种解决方案,可能涉及初始模型加载的惰性评估?我想做的事有可能吗?我应该只在验证之上定义方法,还是有更好的验证解决方案来实现我想要的。

Ruby 正则表达式,只有一次捕获(非常简单!)

我想这将是一个愚蠢的错误,但对我来说,以下返回一个仅包含“M”的数组。看这个:/(.)+?/.match("Manymanycharacters!").captures=>["M"]为什么它不返回每个字符的数组?我一定是错过了一些明显的东西,因为我看不出这有什么问题?编辑:刚刚意识到,我不需要+?但没有它仍然无法工作。编辑:抱歉!我会澄清:我的目标是让用户输入正则表达式和样式以及输入文本文件,只要有匹配项,文本就会被html元素包围并应用样式,我不只是拆分将字符串转换为字符,我只使用了给定的正则表达式,因为它是最简单的,尽管这对我来说很愚蠢。我如何从scan()获取捕获组或者这是不可能